import router from '@/router'
import store from '@/store'

// 全局的路由守卫
router.beforeEach(async(to, from, next) => {
  const token = store.state.user.token
  const nextTo = ['/login', '/404']
  if (token) {
    // 登录
    if (to.path === '/login') return next('/')
    // 选择在这里获取用户信息
    // 1. 看见了花裤衩在这里获取的
    // 2. 有一些业务需要结合
    // 发送请求获取用户数据
    if (store.state.user.userInfo.id) {
      next()
    } else {
      const { roles } = await store.dispatch('user/getUserInfo')
      console.log(roles)
      // console.log(varRoutes)
      store.dispatch('permission/filterRoute', roles)
      // filterRouter: 根据全部动态路由进行筛选之后的动态路由
      // 进入路由
      // console.log(to.path)
      next(to.path)
    }
  } else {
    if (nextTo.includes(to.path)) {
      next()
    } else {
      next('/login')
    }
  }
})
